package com.sg.model.app.po;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
import java.io.Serial;
import lombok.experimental.Accessors;

import jakarta.validation.constraints.NotNull;
import java.io.Serializable;
import java.util.Date;

/**
 *
 *
 * @author xxx
 */
@Data
@Accessors(chain = true)
@TableName("oms_question")   //3-7-02问题表
public class OmsQuestion implements Serializable {

  @Serial
    private static final long serialVersionUID = 1L;

  /**
   * 问题ID
   */
  @TableId(value = "question_id", type = IdType.ASSIGN_UUID)
  @NotNull(message = "questionId不能为空")
  private String questionId;

  /**
   * 内容表类型编码 ORG_OR_DEPT:组织或部门 INTELLIGENT_HARDWARE_EQUIPMENT:智能硬件设备 OMS_TARGET_CYCLE:目标周期表 OMS_EVALUATION_OBJECT_TARGET_CYCLE:被评对象目标周期表 OMS_TARGET:目标表 OMS_TARGET_CATEGORY:目标分类表 OMS_TARGET_OBJECTIVE:指标表 OMS_TASK:任务表 OMS_ORG_INDUCTION_RECORD:就职记录表 OMS_FRAMEWORK_ORIGINAL_ROLE_MEMBER:身份人员表 OMS_ORG_DEPT:部门表 OMS_BASE_HOST:宿主表 OMS_FRAMEWORK_SPACE:空间表 OMS_TSPE_CYCLE_STAGE_DATA:周期阶段资料记录 OMS_EVALUATION_TEMPLATE:评价模板 OMS_EVALUATION_PORTRAIT:评价画像表 OMS_ORG_POSITION:职务表 OMS_VIRTUAL_ORG_MEMBER:虚拟组织成员表 OMS_PLANNING:规划资料表 OMS_FRAMEWORK_USERS:个人账号表 OMS_EXECUTE_CYCLE_STAGE:执行周期阶段表 OMS_CONF_SCHEME:配置方案表 OMS_EVA_OBJ_TARGET_CYCLE_OSET:被评对象目标周期目标设置表 OMS_EVA_OBJ_TARGET_CYCLE_WEIGHT_SET:被评对象目标周期权重设置表 OMS_NOTICE:通知公告表 OMS_CYCLE:周期表 OMS_EVALUATION_SUBJECT:评价主题表 OMS_BIZ_APP_BATCH:业务应用批次表 OMS_EVA_BATCH_RELATED_SET:评价模板批次相关设置表 OMS_TARGET_CYCLE_PLAN_SET:目标周期规划设置表 OMS_TARGET_OBJECTIVE_PLAN_EXTEND:指标扩展规划设置表 OMS_MESSAGE_CHANNEL:通道表 OMS_ORG_ORGANIZATION:组织表 OMS_PROJECT:项目表 OMS_ORG_DEPT:部门表 OMS_QUESTION:问题表 OMS_OFFICIAL_DOCUMENT:公文表
   */
  @TableField(value = "table_type_code")
  @Schema(description = "内容表类型编码")
  private String tableTypeCode;

  /**
   * 系统对接应用类型编码
   */
  @TableField(value = "docking_app_type_code")
  @Schema(description = "系统对接应用类型编码")
  private String dockingAppTypeCode;

  /**
   * 主体生命周期 CURRENTLY_VALID:当前有效 EDITING:正在编辑 ARCHIVING:历史存档
   */
  @TableField(value = "subject_life_cycle")
  @NotNull(message = "主体生命周期不能为空")
  @Schema(description = "主体生命周期")
  private String subjectLifeCycle;

  /**
   * 操作人就职记录ID
   */
  @TableField(value = "operation_induction_id")
  @NotNull(message = "操作人就职记录ID不能为空")
  @Schema(description = "操作人就职记录ID")
  private String operationInductionId;

  /**
   * 创建于空间ID
   */
  @TableField(value = "space_id")
  @NotNull(message = "创建于空间ID不能为空")
  @Schema(description = "创建于空间ID")
  private String spaceId;

  /**
   * 归属主体排序
   */
  @TableField(value = "order_number")
  @NotNull(message = "归属主体排序不能为空")
  @Schema(description = "归属主体排序")
  private Long orderNumber;

  /**
   * 安排主体ID
   */
  @TableField(value = "arrange_subject_id")
  @NotNull(message = "安排主体ID不能为空")
  @Schema(description = "安排主体ID")
  private String arrangeSubjectId;

  /**
   * 是否超时 TRUE:是 FALSE:否
   */
  @TableField(value = "is_overtime")
  @NotNull(message = "是否超时不能为空")
  @Schema(description = "是否超时")
  private String isOvertime;

  /**
   * 内容表主键ID
   */
  @TableField(value = "entity_id")
  @Schema(description = "内容表主键ID")
  private String entityId;

  /**
   * 系统对接应用ID
   */
  @TableField(value = "docking_app_id")
  @Schema(description = "系统对接应用ID")
  private String dockingAppId;

  /**
   * 是否存档 TRUE:是 FALSE:否
   */
  @TableField(value = "is_archive")
  @NotNull(message = "是否存档不能为空")
  @Schema(description = "是否存档")
  private String isArchive;

  /**
   * 创建人就职记录ID
   */
  @TableField(value = "create_induction_id")
  @NotNull(message = "创建人就职记录ID不能为空")
  @Schema(description = "创建人就职记录ID")
  private String createInductionId;

  /**
   * 创建于联盟应用ID
   */
  @TableField(value = "app_id")
  @NotNull(message = "创建于联盟应用ID不能为空")
  @Schema(description = "创建于联盟应用ID")
  private String appId;

  /**
   * 相关人数量
   */
  @TableField(value = "relevant_people_num")
  @NotNull(message = "相关人数量不能为空")
  @Schema(description = "相关人数量")
  private Long relevantPeopleNum;

  /**
   * 安排主体类型编码 OMS_ORG_ORGANIZATION:组织表 OMS_ORG_DEPT:部门表
   */
  @TableField(value = "arrange_subject_type_code")
  @NotNull(message = "安排主体类型编码不能为空")
  @Schema(description = "安排主体类型编码")
  private String arrangeSubjectTypeCode;

  /**
   * 问题标识
   */
  @TableField(value = "question_code")
  @NotNull(message = "问题标识不能为空")
  @Schema(description = "问题标识")
  private String questionCode;

  /**
   * 问题已过时长
   */
  @TableField(value = "over_time_length")
  @Schema(description = "问题已过时长")
  private Double overTimeLength;

  /**
   * 实际解决时间
   */
  @TableField(value = "actual_solve_time")
  @Schema(description = "实际解决时间")
  private Date actualSolveTime;

  /**
   * 父内容表类型编码 ORG_OR_DEPT:组织或部门 INTELLIGENT_HARDWARE_EQUIPMENT:智能硬件设备 OMS_TARGET_CYCLE:目标周期表 OMS_EVALUATION_OBJECT_TARGET_CYCLE:被评对象目标周期表 OMS_TARGET:目标表 OMS_TARGET_CATEGORY:目标分类表 OMS_TARGET_OBJECTIVE:指标表 OMS_TASK:任务表 OMS_ORG_INDUCTION_RECORD:就职记录表 OMS_FRAMEWORK_ORIGINAL_ROLE_MEMBER:身份人员表 OMS_ORG_DEPT:部门表 OMS_BASE_HOST:宿主表 OMS_FRAMEWORK_SPACE:空间表 OMS_TSPE_CYCLE_STAGE_DATA:周期阶段资料记录 OMS_EVALUATION_TEMPLATE:评价模板 OMS_EVALUATION_PORTRAIT:评价画像表 OMS_ORG_POSITION:职务表 OMS_VIRTUAL_ORG_MEMBER:虚拟组织成员表 OMS_PLANNING:规划资料表 OMS_FRAMEWORK_USERS:个人账号表 OMS_EXECUTE_CYCLE_STAGE:执行周期阶段表 OMS_CONF_SCHEME:配置方案表 OMS_EVA_OBJ_TARGET_CYCLE_OSET:被评对象目标周期目标设置表 OMS_EVA_OBJ_TARGET_CYCLE_WEIGHT_SET:被评对象目标周期权重设置表 OMS_NOTICE:通知公告表 OMS_CYCLE:周期表 OMS_EVALUATION_SUBJECT:评价主题表 OMS_BIZ_APP_BATCH:业务应用批次表 OMS_EVA_BATCH_RELATED_SET:评价模板批次相关设置表 OMS_TARGET_CYCLE_PLAN_SET:目标周期规划设置表 OMS_TARGET_OBJECTIVE_PLAN_EXTEND:指标扩展规划设置表 OMS_MESSAGE_CHANNEL:通道表 OMS_ORG_ORGANIZATION:组织表 OMS_PROJECT:项目表 OMS_ORG_DEPT:部门表 OMS_QUESTION:问题表 OMS_OFFICIAL_DOCUMENT:公文表
   */
  @TableField(value = "parent_table_type_code")
  @Schema(description = "父内容表类型编码")
  private String parentTableTypeCode;

  /**
   * 业务应用标识
   */
  @TableField(value = "biz_app_code")
  @NotNull(message = "业务应用标识不能为空")
  @Schema(description = "业务应用标识")
  private String bizAppCode;

  /**
   * 发布人就职记录ID
   */
  @TableField(value = "release_induction_id")
  @Schema(description = "发布人就职记录ID")
  private String releaseInductionId;

  /**
   * 接收部门ID
   */
  @TableField(value = "receive_subject_id")
  @NotNull(message = "接收部门ID不能为空")
  @Schema(description = "接收部门ID")
  private String receiveSubjectId;

  /**
   * 问题编号
   */
  @TableField(value = "question_number")
  @Schema(description = "问题编号")
//  @LikeFlag(likeType = "LIKE")
  private String questionNumber;

  /**
   * 问题文字简介
   */
  @TableField(value = "question_introduce")
  @NotNull(message = "问题文字简介不能为空")
  @Schema(description = "问题文字简介")
//  @LikeFlag(likeType = "LIKE")
  private String questionIntroduce;

  /**
   * 实际解决天数
   */
  @TableField(value = "actual_solve_cycle")
  @Schema(description = "实际解决天数")
  private Long actualSolveCycle;

  /**
   * 父内容表主键ID
   */
  @TableField(value = "parent_entity_id")
  @Schema(description = "父内容表主键ID")
  private String parentEntityId;

  /**
   * 业务场景编码
   */
  @TableField(value = "biz_scene_code")
  @NotNull(message = "业务场景编码不能为空")
  @Schema(description = "业务场景编码")
  private String bizSceneCode;

  /**
   * 存档人就职记录ID
   */
  @TableField(value = "archive_induction_id")
  @Schema(description = "存档人就职记录ID")
  private String archiveInductionId;

  /**
   * 冗余来源类型编码
   */
  @TableField(value = "source_type_code")
  @Schema(description = "冗余来源类型编码")
  private String sourceTypeCode;

  /**
   * 问题文字描述
   */
  @TableField(value = "question_desc")
  @Schema(description = "问题文字描述")
  private String questionDesc;

  /**
   * 问题等级 FATAL:致命 SERIOUS:严重 GENERAL:一般 TINY:微小
   */
  @TableField(value = "question_level")
  @NotNull(message = "问题等级不能为空")
  @Schema(description = "问题等级")
  private String questionLevel;

  /**
   * 主题内容类型编码 ORG_OR_DEPT:组织或部门 INTELLIGENT_HARDWARE_EQUIPMENT:智能硬件设备 OMS_TARGET_CYCLE:目标周期表 OMS_EVALUATION_OBJECT_TARGET_CYCLE:被评对象目标周期表 OMS_TARGET:目标表 OMS_TARGET_CATEGORY:目标分类表 OMS_TARGET_OBJECTIVE:指标表 OMS_TASK:任务表 OMS_ORG_INDUCTION_RECORD:就职记录表 OMS_FRAMEWORK_ORIGINAL_ROLE_MEMBER:身份人员表 OMS_ORG_DEPT:部门表 OMS_BASE_HOST:宿主表 OMS_FRAMEWORK_SPACE:空间表 OMS_TSPE_CYCLE_STAGE_DATA:周期阶段资料记录 OMS_EVALUATION_TEMPLATE:评价模板 OMS_EVALUATION_PORTRAIT:评价画像表 OMS_ORG_POSITION:职务表 OMS_VIRTUAL_ORG_MEMBER:虚拟组织成员表 OMS_PLANNING:规划资料表 OMS_FRAMEWORK_USERS:个人账号表 OMS_EXECUTE_CYCLE_STAGE:执行周期阶段表 OMS_CONF_SCHEME:配置方案表 OMS_EVA_OBJ_TARGET_CYCLE_OSET:被评对象目标周期目标设置表 OMS_EVA_OBJ_TARGET_CYCLE_WEIGHT_SET:被评对象目标周期权重设置表 OMS_NOTICE:通知公告表 OMS_CYCLE:周期表 OMS_EVALUATION_SUBJECT:评价主题表 OMS_BIZ_APP_BATCH:业务应用批次表 OMS_EVA_BATCH_RELATED_SET:评价模板批次相关设置表 OMS_TARGET_CYCLE_PLAN_SET:目标周期规划设置表 OMS_TARGET_OBJECTIVE_PLAN_EXTEND:指标扩展规划设置表 OMS_MESSAGE_CHANNEL:通道表 OMS_ORG_ORGANIZATION:组织表 OMS_PROJECT:项目表 OMS_ORG_DEPT:部门表 OMS_QUESTION:问题表 OMS_OFFICIAL_DOCUMENT:公文表
   */
  @TableField(value = "theme_content_type_code")
  @Schema(description = "主题内容类型编码")
  private String themeContentTypeCode;

  /**
   * 操作时间
   */
  @TableField(value = "operate_time")
  @NotNull(message = "操作时间不能为空")
  @Schema(description = "操作时间")
  private Date operateTime;

  /**
   * 问题图片描述
   */
  @TableField(value = "question_img")
  @Schema(description = "问题图片描述")
  private String questionImg;

  /**
   * 问题状态 QUESTIONABILITY:待解决 RESOLVED:已解决 OVERTIME:已超时 SHELVE:暂搁置 REJECTED:已拒绝 SUSPENDED:已挂起 CLOSED:已关闭
   */
  @TableField(value = "question_status")
  @NotNull(message = "问题状态不能为空")
  @Schema(description = "问题状态")
  private String questionStatus;

  /**
   * 主题内容ID
   */
  @TableField(value = "theme_content_id")
  @Schema(description = "主题内容ID")
  private String themeContentId;

  /**
   * 创建时间
   */
  @TableField(value = "create_time")
  @NotNull(message = "创建时间不能为空")
  @Schema(description = "创建时间")
  private Date createTime;

  /**
   * 状态备注
   */
  @TableField(value = "remarks")
  @Schema(description = "状态备注")
  private String remarks;

  /**
   * 归属对象类型编码 OMS_ORG_DEPT:部门表 OMS_FRAMEWORK_SPACE:空间表 OMS_PROJECT:项目表 OMS_TASK:任务表
   */
  @TableField(value = "coord_object_type_code")
  @Schema(description = "归属对象类型编码")
  private String coordObjectTypeCode;

  /**
   * 发布时间
   */
  @TableField(value = "release_time")
  @Schema(description = "发布时间")
  private Date releaseTime;

  /**
   * 归属对象ID
   */
  @TableField(value = "coord_object_id")
  @Schema(description = "归属对象ID")
  private String coordObjectId;

  /**
   * 是否私密 TRUE:是 FALSE:否
   */
  @TableField(value = "is_private")
  @NotNull(message = "是否私密不能为空")
  @Schema(description = "是否私密")
  private String isPrivate;

  /**
   * 存档时间
   */
  @TableField(value = "archive_time")
  @Schema(description = "存档时间")
  private Date archiveTime;

  /**
   * 是否作废 TRUE:是 FALSE:否
   */
  @TableField(value = "is_valid")
  @NotNull(message = "是否作废不能为空")
  @Schema(description = "是否作废")
  private String isValid;
}
